草庐IT

Java 配置框架

全部标签

java - 我将如何在 Java 中实现 Go 的无缓冲 channel ?

Go同时提供unbufferedandbufferedchannels用于goroutines(线程)之间的通信。是straightforward在Java中将缓冲channel实现为有界缓冲区。Go的无缓冲channel要求一个协程在另一个协程接收时发送。任何人都可以向我解释如何在Java中实现它吗? 最佳答案 在Java中你可以使用SynchronousQueue,Java8的源代码在这里http://grepcode.com/file/repository.grepcode.com/java/root/jdk/openjdk/

go - 如何使用 google/jsonapi 和 echo 框架返回有效的 jsonapi 响应

下面的代码返回两个连接的JSON字符串和一个错误的内容类型text/plain。应该是application/vnd.api+jsonpackagemainimport("github.com/google/jsonapi""github.com/labstack/echo""net/http")typeAlbumstruct{IDint`jsonapi:"primary,albums"`Namestring`jsonapi:"attr,name"`}funcmain(){e:=echo.New()e.GET("/",func(cecho.Context)error{jsonapi.M

go - 没有任何网络框架的GO中URL中的路径参数

在使用Go开发RESTapi时,我们如何使用路径参数?意思是说URI的格式是什么?http://localhost:8765/myapp/{param1}/entries/{param2}我尝试使用类似这样的方法来创建路由,但未调用处理函数。请注意,我打算只使用net/http包,而不是任何其他网络框架,如gorillamux。 最佳答案 我倾向于做的是嵌套处理程序。“/”由根处理程序处理。它弹出路径的第一部分,将其余部分分配回req.URL.Path(有效地类似于StripPrefix),确定哪个处理程序通过该前缀处理路由(如果任

docker - 如何从 docker 容器配置 go sdk 和 GOPATH?

我正在尝试使用JetbrainsGogland和dockercompose配置golang项目。我想使用GOPATH并从docker容器中走出来。我的意思是使用容器中的go安装来进行自动完成等,而无需在本地计算机上安装golang。项目结构是:projectrootdocker-compose.ymlback|Dockerfilemain.gosomeotherpackagesfront|allthefrontfiles...之后,我想将我的back文件夹部署到docker容器中的/go/src/app。问题是当我开发项目时我不能使用自动完成,因为这个项目不在我本地的GOPATH中并且

go - 如何为滚动文件系统日志配置 uber-go/zap 记录器?

如何配置uber-go/zap记录器api将日志附加到指定的文件路径。能否使其像滚动文件附加程序(基于文件大小或日期)一样工作而不影响性能? 最佳答案 一个钩子(Hook)可以添加到zap记录器,它将条目写入lumberjack,Go的滚动日志。一个简单的用法是这样的:滚动日志://remembertocallthisatapp(orscope)exit://logger.Close()varlumlog=&lumberjack.Logger{Filename:"/tmp/my-zap.log",MaxSize:10,//megab

go - 如何将数组中的配置项绑定(bind)到环境变量

下面是我的toml格式的配置文件。[[hosts]]name="host1"username="user1"password="password1"[[hosts]]name="host2"username="user2"password="password2"...这是我加载它的代码:import("fmt""github.com/spf13/viper""strings")typeConfigstruct{Hosts[]Host}typeHoststruct{Namestring`mapstructure:"name"`Usernamestring`mapstructure:"us

go - 使用无服务器框架的 AWS Codebuild Golang Lambda

我正在使用AWSCodeBuild中的无服务器框架构建golanglambda函数。该项目位于私有(private)bitbucket存储库中。CodeBuild源是bitbucket仓库我在代码中使用本地包时遇到了一些问题。我有这个项目结构hellotesttest.gomain.goserverless.yml...otherfiles我想做的是使用包test在hello/test/test.go在hello/main.go.我已经尝试了2个选项。使用“myproject/hello/test”导入包使用bitbucketurl和depensure.搬家test到另一个项目。问题:

go - 如何在 go 中实现碎片化的配置文件验证

我尝试通过配置文件(yaml)配置CLI应用程序。该应用程序有几个“组件”(比方说持久层、集成网络服务器等)。这些组件在子包中进行管理,以保持代码整洁。这些组件的配置在它们的包中定义并在配置包中“合并”到表示配置文件的结构。将此代码视为演示实现:packagemainimport("errors""fmt"yaml"gopkg.in/yaml.v2")////Thiswouldbeinpackage'webserver'//OnlytheConfigpartisshown,therewouldbeaconstructorandtheimplementationof//thewebser

java - 如何使用 JNA 为具有多个返回值的 go 函数编写接口(interface)

我正在尝试导出一些Go函数并在Java中调用它们,使用JNA,但我不知道如何在Java中为具有多个返回值的Go函数定义接口(interface)。假设Go函数是://exportgenerateKeysfuncgenerateKeys()(privateKey,publicKey[]byte){return.....}返回值有两项,但在Java中,只允许有一项返回值。我能做什么? 最佳答案 cgo为多个返回值创建专用的C结构,并将各个返回值作为结构元素。在您的示例中,cgo将生成/*ReturntypeforgenerateKeys

go - 在 golang 中正确映射 YAML 配置文件

我用go编写了一个API,它可以创建具有默认策略规则的组织。我想使用外部配置YAML文件在我的API中包含一些策略(我实际上将这些策略放在我的代码中的函数中,该函数创建了我的实体组织):策略.yml-role:"admin"organisationid:organisation.IDpolicies:[{Object:"/*",Action:"*"}]-role:"user"organisationid:organisation.IDpolicies:[{Object:"/me",Action:"GET"},{Object:"/organisations",Action:"GET"},